/*
 * GestionEnvioDAO.java
 *
 * Created on 23 de octubre de 2007, 04:00 PM
 *
 * To change this template, choose Tools | Options and locate the template under
 * the Source Creation and Management node. Right-click the template and choose
 * Open. You can then make changes to the template in the Source Editor.
 */

package com.src.computec.radar.services.utilities.dao;

import com.src.computec.radar.base.dao.GenericDAO;
import com.src.computec.radar.base.dao.exception.DAOException;
import com.src.computec.radar.services.base.constantes.ConstantesGenerales;
import com.src.computec.radar.services.utilities.dto.GestionEnvioDto;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

/**
 *
 * @author aocampo
 */
public class GestionEnvioDAO extends GenericDAO implements BaseGestionEnvioDAO {
    
    /** Creates a new instance of GestionEnvioDAO */
    public GestionEnvioDAO() {
    }   
    
    /**
    * Retorna una lista con las Gestiones segun el tipo de gestion recibido
    *
    * @param tipoGestionEnvioId String con el codigo del tipo de gestion
    * @return List con las gestiones del tipo especificado.
    */
    public List getGestionEnvioByTipoGestionEnvioId(String tipoGestionEnvioId) throws DAOException {
        List listGestionEnvio = new ArrayList();
        Connection con = null;
        PreparedStatement statement = null;
        ResultSet rs = null;
        try {
            con = getConnectionDB2();
            statement = con.prepareStatement("SELECT CODIGO_GESTION, NOMBRE_GESTION, CODIGO_TIPO_GESTION " +
                                             "FROM " + ConstantesGenerales.getInstance().SCHEMA + ".GESTION_ENVIO " +
                                             " WHERE CODIGO_TIPO_GESTION = ? " +
                                             "ORDER BY NOMBRE_GESTION ASC");
            int indice = 0;
            statement.setObject(++indice, ConstantesGenerales.getInstance().GESTION_ENVIO);
            rs = statement.executeQuery();
            while (rs.next()) {
                indice = 0;
                GestionEnvioDto gestionEnvioDto = new GestionEnvioDto();
                gestionEnvioDto.setCodigoGestion(rs.getString(++indice));
                gestionEnvioDto.setNombreGestion(rs.getString(++indice));
                gestionEnvioDto.setCodigoTipoGestion(rs.getString(++indice));
                listGestionEnvio.add(gestionEnvioDto);
            }
        }
        catch (SQLException e) {
            throw new DAOException("GestionEnvioDAO:getGestionEnvioByTipoGestionEnvioId: " + e.toString(), e);
        }
        finally {
            closeConnection(con, statement, rs);
        }
        return listGestionEnvio;
    }
}